JavaScript - tutorial - 29 - search webpage

Revision:


Content

search() method search() method: examples matchAll() method in-page filtered search in-page filter search images


search() method

top

The search() method, which is "case-sensitive", matches a string against a regular expression. If the search value is a string, it is converted to a regular expression. It returns the index (position) of the first match, but returns -1 if no match is found.

syntax: string.search(searchValue)

searchValue: required; the search value, i.e. a regular expression (or a string that will be converted to a regular expression).


search() method: examples

top

search string

code:
                <div class="spec">
                    <p id="initial"></p>
                    <p id="search"></p>
                    <p id="search1"></p>
                    <p id="search2"></p>
                    <p id="search3"></p>
                    <p id="search4"></p>
                
                </div>
                <script>
                let text = "Mr. Blue has a blue house"
                document.getElementById("initial").innerHTML = "text : " + text;
                let position = text.search("Blue");
                document.getElementById("search").innerHTML = " 'Blue' position: " + position;
                let position2 = text.search("blue");
                document.getElementById("search1").innerHTML = " 'blue' position: " + position2;
                let position3 = text.search(/Blue/);
                document.getElementById("search2").innerHTML = " /Blue/ position: " + position3;
                let position4 = text.search(/blue/);
                document.getElementById("search3").innerHTML = " /blue/ position: " +position4;
                let position5 = text.search(/blue/i);
                document.getElementById("search4").innerHTML =  " /blue/i position: " + position5;
                </script>
            

search string in list

code:
            <div class="spec">
                <!-- (A) SEARCH BOX -->
                <input type="text" id="the-filter" placeholder="Search For..."/>
                <!-- (B) LIST OF ITEMS -->
                <ul id="the-list">
                    <li>Apple</li>
                    <li>Apricots</li>
                    <li>Avocado</li>
                    <li>Banana</li>
                    <li>Blackberries</li>
                    <li>Blueberries</li>
                    <li>Cherries</li>
                    <li>Coconut</li>
                    <li>Cranberries</li>
                    <li>Durian</li>
                    <li>Elderberries</li>
                    <li>Grapefruit</li>
                    <li>Grapes</li>
                    <li>Guava</li>
                    <li>Honeydew</li>
                    <li>Jackfruit</li>
                    <li>Longan</li>
                    <li>Loquat</li>
                    <li>Mango</li>
                    <li>Orange</li>
                    <li>Papaya</li>
                    <li>Pear</li>
                    <li>Pineapple</li>
                    <li>Strawberries</li>
                    <li>Watermelon</li>
                </ul>
            </div>
            <style>
                /* (a) search box*/
                #the-filter {box-sizing: border-box; width: 100%; margin-bottom: 1.5vw; padding: 1vw;}
                /* (b) list */
                #the-list {list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(10,1fr);}
                #the-list li {padding: 1vw; border-bottom: 0.2vw solid #ffe9e9;}
                #the-list li:hover { background: #fffed6; }
                #the-list li.hide { display: none; }
            </style>
            <script>
            window.addEventListener("load", () => {
                    // (a) get HTML elements
                    var filter = document.getElementById("the-filter"), 
                        list = document.querySelectorAll("#the-list li"); 
                    // (b) attach keyup listener to search box
                    filter.onkeyup = () => {
                        // (b1)get current search term
                        let search = filter.value.toLowerCase();
                        // (b2) loop through the list items - only show those that match the search
                        for (let i of list) {
                            let item = i.innerHTML.toLowerCase();
                            if (item.indexOf(search) == -1) { i.classList.add("hide"); }
                            else { i.classList.remove("hide"); }
                        }
                    };
                });
    
            </script>
            
        

JavaScript - simple search bar

code:
            <div class="spec">
                <h4>JavaScript - simple search bar</h4>
                <div>
                    <input type="text" id="search5" placeholder="Search here..." 
                    onkeyup="searchList()" class="form-control"/>
                </div>
                <ul class="list-group" id="list">
                    <li class='list-group-item'>1. Apple</li>
                    <li class='list-group-item'>2. Banana</li>
                    <li class='list-group-item'>3. Cat</li>
                    <li class='list-group-item'>4. Dog</li>
                    <li class='list-group-item'>5. Eggplant</li>
                    <li class='list-group-item'>6. Flame</li>
                </ul>
            </div>
            <script>
                function searchList(){
                    var search = document.getElementById('search5').value.toLowerCase();
                    var target = document.getElementById("list");
                    var list = target.getElementsByTagName('li');
                    for(var i=0; i < list.length; i++){
                        var text = list[i].innerHTML;
                        if(text.toLowerCase().indexOf(search) > -1){
                            list[i].style.display = "";
                        }else{
                            list[i].style.display = "none";
                        }
                    }
                }
            </script>
        

search input

code:
            <div class="spec">
                <form id="form" role="search">
                    <input type="search" id="query" name="q" placeholder="Search..." 
                    aria-label="Search through site content">
                    <button>
                        <svg viewBox="0 0 1024 1024"><path class="path1" d="M848.471 
                        928l-263.059-263.059c-48.941 36.706-110.118 55.059-177.412 55.059-
                        171.294 0-312-140.706-312-312s140.706-312 312-312c171.294 0 312 140.706
                        312 312 0 67.294-24.471 128.471-55.059 177.412l263.059 263.059-79.529
                        79.529zM189.623 408.078c0 121.364 97.091 218.455 218.455 218.455s218.455
                        -97.091 218.455-218.455c0-121.364-103.159-218.455-218.455-218.455-121.364
                        0-218.455 97.091-218.455 218.455z"></path></svg>
                    </button>
                    
                </form>
            </div>
            <style>
                #form {background-color: #4654e1; width: 30vw; height: 4.4vw; border-radius: 0.5vw; 
                    display: flex; flex-direction: row;
                align-items: center;}
                #query {all:unset; font: 1.6vw system-ui; color: #fff; height: 100%; width: 100%; 
                    padding: 0.6vw 1vw;}
                ::placeholder { color: #fff; opacity: 0.7; }
                button {all: unset; cursor: pointer; width: 4.4vw; height: 4.4vw;}
                svg { color: #fff; fill: currentColor; width: 2.4vw; height: 2.4vw; padding: 1vw;}
            </style>
            <script>
                const f = document.getElementById('form');
                const q = document.getElementById('query');
                const google = 'https://www.google.com/search?q=site%3A+';
                const site = 'lwitters.com';
    
                function submitted(event) {
                    event.preventDefault();
                    const url = google + site + '+' + q.value;
                    const win = window.open(url, '_blank');
                    win.focus();
                }
                f.addEventListener('submit', submitted);
            </script>
        

search results

code:
            <div class="spec">
                <p id="property16"></p>
                <p id="property15"> </p>
    
            </div>
            <script>
                
                var re = /apples/gi;
                var str = "Apples are round, and apples are juicy.";
                document.getElementById("property16").innerHTML = "original sentence: 
                Apples are round, and apples are juicy.";
                if (str.search(re) == -1 ) {
                    document.getElementById("property15").innerHTML = " search result: 
                    does not contain 'Apples'";
                } else {
                    document.getElementById("property15").innerHTML = " search result: 
                    contains 'Apples'";
                }
            </script>
        

matchAll() method

top

The matchAll() method returns an iterator of all results matching a string against a regular expression, including capturing groups. This method can be used to capture groups with the /g flag giving it an advantage over the match() method, which ignores capturing groups with the /g flag.

Syntax: matchAll(regexp)

parameters:

regexp: a regular expression object, or any object that has a "Symbol.matchAll" method. If regexp is not a RegExp object and does not have a "Symbol.matchAll" method, it is implicitly converted to a RegExp by using new RegExp(regexp, 'g'). If regexp is a RegExp object (via the IsRegExp check), then it must have the global (g) flag set, or a TypeError is thrown.

return value:

an iterable iterator (which is not restartable) of matches. Each match is an array with the same shape as the return value of RegExp.prototype.exec().

code:
                    <div class="spec">
                        <p id="match1"></p>
                        <p id="match2"></p>
                    </div>
                    <script>
                        const regexp = /t(e)(st(\d?))/g;
                        const str2 = 'test1test2';
                        const array = [...str2.matchAll(regexp)];
                        console.log(array[0]); // expected output: Array ["test1", "e", "st1", "1"]
                        document.getElementById("match1").innerHTML = array[0];
                        console.log(array[1]); // expected output: Array ["test2", "e", "st2", "2"]
                        document.getElementById("match2").innerHTML = array[1];
                    </script>
                

code:
                    <div class="spec">
                        <p id="match3"></p>
                        <p id="match4"></p>
                    </div>
                    <script>
                        const regexp1 = /foo[a-z]*/g;
                        const str3 = 'table football, foosball';
                        const matches = str3.matchAll(regexp1);
                        for (const match of matches) {
                        document.getElementById("match3").innerHTML += `Found ${match[0]} 
                        start=${match.index} end=${match.index + match[0].length}. <br>` ;
                        console.log(`Found ${match[0]} start=${match.index} end=${match.index + 
                            match[0].length}.`);
                        }
                        // expected output: "Found football start=6 end=14."
                        // expected output: "Found foosball start=16 end=24."
            
                        // matches iterator is exhausted after the for..of iteration
                        // Call matchAll again to create a new iterator
                        Array.from(str3.matchAll(regexp1), (m) => m[0]);
                        // Array [ "football", "foosball" ]
                    </script>
                

in-page filtered search

top

SuperHero FAQ

Frequently Asked Question about Superhero

code:
            <div class="spec">
                <div class="columns mx-1">
                    <div class="column is-half is-offset-one-quarter">
                    <section class="hero is-primary mb-4">
                        <div class="hero-body">
                        <p class="title">SuperHero FAQ</p>
                        <p class="subtitle">Frequently Asked Question about Superhero</p>
                        </div>
                    </section>
                    <section>
                        <div>
                            <label for="searchbox" class="is-size-5">Search</label>
                            <input class='input mb-5' type="search" id="searchbox" 
                            oninput="liveSearch()" placeholder="Live search keyword..">
                        </div>
                        <div class="box is-hidden">
                            <strong>What is Kryptonite?</strong>
                            <p> It's Superman's weakness</p>
                        </div>
                        <div class="box  is-hidden">
                            <strong> How did Spider-man get superpowers?</strong>
                            <p>  Spider-man was bitten by a radioactive spider on a lab. </p>
                            <!-- Put any keywords here -->
                            <span class="is-hidden">secret</span> 
                        </div>
                        <div class="box  is-hidden" >
                            <strong>Who were Batman's parents?</strong>
                            <p> Thomas Wayne and Martha Wayne. </p>
                        </div>
                        <div class="box  is-hidden">
                            <strong>Who is Malekith?</strong>
                            <p>The villain of 'Thor: The Dark World' </p>
                        </div>
                        <div class="box  is-hidden">
                            <strong>What's Wonder Woman's weapon?</strong>
                            <p>A magic lasso and bullet-proof bracelets </p>
                        </div>
                        <div class="box  is-hidden">
                            <strong>What's Strom super power?</strong>
                            <p>She can manipulate and resist the weather</p>
                        </div>
                        <div class="box  is-hidden">
                            <strong>What's Strom super power?</strong>
                            <p>She can manipulate and resist the weather</p>
                        </div>
                        <div class="box  is-hidden">
                            <strong>What is Eye of Agamotto?</strong>
                            <p>It's a place where the Time Stone is hidden in Doctor Strange </p>
                        </div>
                        <div class="box  is-hidden">
                            <strong>What is Paradise Island?</strong>
                            <p>It's where Wonder Woman comes from. </p>
                        </div>
                        <div class="box  is-hidden">
                            <strong>Who was the sidekick of Aquaman?</strong>
                            <p>The sidekick of Aquaman, is someone called Aqualad. </p>
                        </div>
                    </section>
                    </div>
                </div>
            </div>
            <style>
                .is-hidden{display:none;}
            </style>
            <script>
                let cards = document.querySelectorAll('.box')
                function liveSearch() {
                    let search_query = document.getElementById("searchbox").value;
                    //Use innerText if all contents are visible
                    //Use textContent for including hidden elements
                    for (var i = 0; i < cards.length; i++) {
                        if(cards[i].textContent.toLowerCase()
                                .includes(search_query.toLowerCase())) {
                            cards[i].classList.remove("is-hidden");
                        } else {
                            cards[i].classList.add("is-hidden");
                        }
                    }
                }
                
                //A little delay
                let typingTimer;               
                let typeInterval = 500;  
                let searchInput = document.getElementById('searchbox');
                
                searchInput.addEventListener('keyup', () => {
                    clearTimeout(typingTimer);
                    typingTimer = setTimeout(liveSearch, typeInterval);
                });
            </script>
        

in-page filter search images

top

Gallery of holidays pictures

Images from my website

code:
            <div class="spec">
                <div class="columns mx-1">
                    <div class="column is-half is-offset-one-quarter">
                        <section class="hero is-primary mb-4">
                            <div class="hero-body">
                                <p class="title">Gallery of holidays pictures</p>
                                <p class="subtitle">Images from my website</p>
                            </div>
                        </section>
                        <section>
                            <div>
                                <label for="searchbox1" class="is-size-5">Search</label>
                                <input class='input mb-5' type="search" id="searchbox1" oninput="liveImage()"placeholder="Live search keyword..">
                            </div>
                            <div>
                                <img class='image is-hidden' src="../../pics/1.jpg" width="50%" height="auto" alt="on the lake" />
                                <img class='image is-hidden' src="../../pics/2.jpg" width="50%" height="auto" alt="beach view" />
                                <img class='image is-hidden' src="../../pics/3.jpg" width="50%" height="auto" alt="ready for a shower" />
                                <img class='image is-hidden' src="../../pics/4.jpg" width="50%" height="auto" alt="becoming a sailor" />
                                <img class='image is-hidden' src="../../pics/5.jpg" width="50%" height="auto" alt="relaxing under the palm trees" />
                            </div>
                        </section>
                    </div>
                </div>
            </div>
            <style>
                .is-hidden{display: none;}
            </style>
            <script>
                let boxes = document.querySelectorAll('.image')
                function liveImage() {
                    let search_query = document.getElementById("searchbox1").value;
                    for (var i = 0; i < boxes.length; i++) {
                        if (boxes[i].getAttribute('alt').toLowerCase().includes(search_query.toLowerCase())) {
                            boxes[i].classList.remove("is-hidden");
                        } else {
                            boxes[i].classList.add("is-hidden");
                        }
                    }
                }
                //A little delay
                let typingTimer1;
                let typeInterval1 = 500;
                let searchInput1 = document.getElementById('searchbox');
                
                searchInput1.addEventListener('keyup', () => {
                    clearTimeout(typingTimer1);
                    typingTimer1 = setTimeout(liveSearch, typeInterval1);
                });
        
            </script>
        


functional search bar with JavaScript

Search for a fruit

code:
            <div>
                <section class="containerA">
                    <h4>Search for a fruit</h4>
                    <input type="search" id="searchA" onkeyup="mySearch()" placeholder="Search for fruit.." title="Type in a fruit" aria-label="search">
                    <ul class="card-containerA grid3">
                        <li><a href="#">Apples</a></li>
                        <li><a href="#">Bananas</a></li>
                        <li><a href="#">Grapes</a></li>
                        <li><a href="#">Mangos</a></li>
                        <li><a href="#">Oranges</a></li>
                        <li><a href="#">Pineapples</a></li>
                        <li><a href="#">Strawberries</a></li>
                    </ul>
                </section>
            </div>
            <style>
                .card-containerA {list-style-type: none; margin-top: 1rem;}
                .card-containerA li a {margin-block: .5rem; background-color: #222; color: #f1f1f1; padding: 1rem;
                text-decoration: none; text-align: center; display: block;}
                .card-containerA li a:hover:not(.header) { transform: scale(1.05);}
            </style>
            <script>
                function mySearch() {
                    var input, filter, ul, li, a, i, txtValue;
                        input = document.querySelector("#searchA");
                        filter = input.value.toUpperCase();
                        ul = document.querySelector(".card-containerA");
                        li = ul.getElementsByTagName("li");
                    for (i = 0; i < li.length; i++) {
                            a = li[i].getElementsByTagName("a")[0];
                            txtValue = a.textContent || a.innerText;
                            if (txtValue.toUpperCase().indexOf(filter) > -1) {
                                li[i].style.display = "";
                            } else {
                                li[i].style.display = "none";
                            }
                    }
                }
            </script>

        


in-page JavaScript search engine

  1. Title - Author's div - here (date)
  2. list of keywords in the paper separated with a space and all lowercase

      Use the search bar to find what you are looking for!! - Type * in the search bar to display all entries.
      You can use the + or - prefixes to oblige word(s) to be present or exlude them, respectively, from the search.

code:
            <div>
                <ol>
                    <div class="theData">
                        <li>Title - <span class="author">Author's div</span> - <a target="_blank" href="link_to_paper">here</a> (date)</li>
                        <span class="BCdico">list of keywords in the paper separated with a space and all lowercase</span>
                    </div>
                <ol>
                <!-- The search bar -->
                <form action="/">
                    <table border="0" cellpadding="0" cellspacing="5" bgcolor="#e9e9e9">
                        <tr>
                            <td align="right" valign="middle"><input id="theSearchString" type="text" placeholder="Search.." name="searchS"></td>
                            <td align="left" valign="middle">
                                <button id="buttonStr" type="button" onClick='doSearch("")'>
                                    <svg width="24" height="24"><circle r="5" cx="6" cy="6" id="C1" style="stroke:#000000;stroke-width:4;fill:yellow;" /><line id="L1" x1="16" y1="16" x2="9" y2="9" 
                                    style="stroke:#000000;stroke-width:3;fill:none;" />
                                    </svg>
                                </button>
                            </td>
                            <td align="center">
                                <input type="radio" id="ro" name="ao" value="ro" checked /><label for="ro">Or</label>
                                <input type="radio" id="ra" name="ao" value="ra" /><label for="ra">And</label><br />
                                <input type="checkbox" id="ww" name="ww" /><label for="ww">Whole words</label>
                            </td>
                        </tr>
                    </table>
                </form>
                <p style="padding-left:16px">Use the search bar to find what you are looking for!!  -  Type * in the search bar to display all entries.<br />
                You can use the <strong>+</strong> or <strong>-</strong> prefixes to oblige word(s) to be present or exlude them, respectively, from the search.</p>
                <!-- end search bar -->
            </div>
            <style>
                .theData{display: none;}
                ol li { border-left:1px solid blue; border-bottom:1px solid darkgrey; padding-bottom:3px; padding-left:5px; }
                strong { color:black; font-weight:bolder; }
                .BCdico {display: none;}
                .author { color:#000066; font-weight:bold; }
                table { width:60vw; padding-top:1vw; padding-bottom:1vw; padding-left:4vw; padding-right:2vw; background-color:lightblue; }
                input[type=text] { padding:8px; margin-top:4px; font-size:15px; border:none; }
                button { background:#ddd; font-size:18px; border:none; cursor:pointer; margin-top:4px; padding-top:8px; padding-bottom:8px; }
                button:hover { background: #CCC; }
                #theSearchString { margin-bottom:0px; width: 600px; }
            </style>
            <script>
                // hide previous results
                function hideResults() {
                    var theData = document.getElementsByClassName('theData'); 
                    for (var p=0; p<theData.length; print++) { 
                        theData[p].style.display = "none";
                    }
                }
                function myReplace(t) {
                // Replace words by others in the user's search string
                    var aro = ['ori1', 'ori2', '...'];       
                    var arr = ['new1', 'new2', '...'];       
                    for (var p=0; p<aro.length; p++) {     
                        var rg = new RegExp(aro[p],'g');   
                        t = t.replace(rg, arr[p]);         
                    }
                    return t;                              
                }
                function toSpace(t) {
                    // Replace ,:\;tab by spaces
                    var rg = new RegExp(',|:|\\||;|\\t','g');  
                    return t.replace(rg,' ');                  
                }
                function bgetOrder(text, d) {
                    // Check for + and - options
                    var lst = [];                              // define the array storing the tagged words
                    var ar = text.split(' ');                  // break the text variable into an array (ar), using space as separator
                    for (p = 0; p < ar.length; p++) {         // Loop through each element of the ar array
                        var t = ar[p];                        // store current array element into variable t
                        if ((t.trim() != '') && (t.slice(0,1) == d)) {  // if +/- is at the beginning of the word
                            lst.push(t.slice(1));             // store the word into the lst array
                        }
                    }
                    while (text.indexOf(d) > -1) {          
                        text = text.replace(d, '');
                    }
                    return [lst, text];                    
                }
                function doSearch() {
                    // Search for words. All matching words return an entry ('or'-type search)
                    // for 'and'-type:
                    //   prefix = "(?=[\s\S]*"  or "(?=[\s\S]*\b" to match exact words
                    //   suffix = ")"           or "\b)"
                    // then
                    //   text = prefix + text.replace(" ", suffix+prefix) + suffix;
                    // finally
                    //   var rg = new RegExp("(" + text + ")");
                    var text = (document.getElementById('theSearchString').value.toLowerCase());
                    var theDico = document.getElementsByClassName('BCdico');
                    var and = document.getElementById("ra").checked;
                    var allWord = document.getElementById("ww").checked;
                    // Following 2 variables are used to beautify the results...
                    var o = 0;                           // results are presented in rows
                    var cc = ['#e5ffe5', '#efffef'];     // with alternating background colours
                    hideResults();
                    text = text.trim();
                    if (text == '') {
                        return 0;
                    } else if (text == '*') {
                        for (var p=0; p<theDico.length; p++) {
                            theDico[p].parentElement.style.display = "block";
                            theDico[p].parentElement.style.backgroundColor = cc[o];
                            o = (o+1) % 2;
                        }
                   } else {
                        text = myReplace(text);
                        text = toSpace(text);
                        var dicP = []; 
                        var dicM = [];
                        if (text.indexOf(' +') > -1) {
                            [dicP, text] = bgetOrder(text,'+');
                        }
                        if (text.indexOf(' -') > -1) {
                            [dicM, text] = bgetOrder(text,'-');
                        }
                        if (and) {
                            var prefix = "(?=[\\s\\S]*";
                            var suffix = ")";
                            if (allWord) {
                                prefix += "\\b";
                                suffix = "\\b" + suffix;
                            }
                            text = prefix + text.replace(/ /g, suffix+prefix) + suffix;
                            var rg = new RegExp(text);
                        } else {
                            if (allWord) {
                                text = "\\b" + text.replace(/ /g,"\\b|\\b") + "\\b";
                                var rg = new RegExp("("+text+")");
                            } else {
                                var rg = new RegExp("("+text.replace(/ /g,"|")+")");
                            }
                        }
                        for (var i=0; i<theDico.length; i++) {
                            var txt = theDico[p].innerHTML;
                            if (txt.search(rg) > -1) {
                                var b = true;
                                if (dicM.length > 0) {
                                    // do not show text containing unwanted word(s)
                                    for (var j=0; j<dicM.length; j++) {
                                        if (txt.indexOf(dicM[j]) > -1) {
                                            b = false;
                                            break;
                                        }
                                    }
                                }
                                if (dicP.length > 0) {
                                    // do not show text that do not contain wanted word(s)
                                    for (var j=0; j<dicP.length; j++) {
                                        if (txt.indexOf(dicP[j]) == -1) {
                                            b = false;
                                            break;
                                        }
                                    }
                                }
                                if (b) {
                                    theDico[p].parentElement.style.display = "block";
                                    theDico[p].parentElement.style.backgroundColor = cc[o];
                                    o = (o+1) % 2;
                                }
                            }
                        }
                    }
                }
            </script>
        


JavaScript search filter

Nothing Found

Audi

BMW

Chevrolet

Dacia

Dodge

Ferrari

Jaguar

Kia

Lamborghini

Lotus

Mercedes

Mini

code:
            <div>
                <div class="search-containerB main-containerB">
                    <i class="fa fa-search"></i>
                    <input type="text" id="search-inputB" placeholder="Search..." autocomplete="off"/>
                </div>
                <div class="main-containerB">
                    <div id="nothing-alert">Nothing Found</div>
                    <div class="cards"><h4 class="icon-name">Audi</h4></div>
                    <div class="cards"><h4 class="icon-name">BMW</h4></div>
                    <div class="cards"><h4 class="icon-name">Chevrolet</h4></div>
                    <div class="cards"><h4 class="icon-name">Dacia</h4></div>
                    <div class="cards"><h4 class="icon-name">Dodge</h4></div>
                    <div class="cards"><h4 class="icon-name">Ferrari</h4></div>
                    <div class="cards"><h4 class="icon-name">Jaguar</h4></div>
                    <div class="cards"><h4 class="icon-name">Kia</h4></div>
                    <div class="cards"><h4 class="icon-name">Lamborghini</h4></div>
                    <div class="cards"><h4 class="icon-name">Lotus</h4></div>
                    <div class="cards"><h4 class="icon-name">Mercedes</h4></div>
                    <div class="cards"><h4 class="icon-name">Mini</h4></div>
                </div>
            </div>
            <style>
                .main-containerB {display: flex; justify-content: flex-start; align-items: center; margin: 15px 40px; flex-wrap: wrap;}
                #nothing-alert{ display: none; width: 100%; margin: 50px auto; text-align: center;}
                .cards {display: flex; justify-content: center; align-items: center; flex-direction: column; width: 80px; height: 80px;        margin: 0.5em; background-color: #fff; border-radius: 3px; box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1); cursor: pointer;       transition: all 0.25s ease; animation: populate 0.5s ease-out normal backwards;}
                .cards:hover { transform: scale(1.05); z-index: 1; box-shadow: 0 5px 12px rgba(0, 0, 0, 0.2);}
                @keyframes populate {
                    0% {transform: scale(0);}
                }
                .icon-name {font-size: 0.7em;text-align: center; margin: 0;}
                .search-containerB{position: relative; height: 4vw; max-width: 40vw; width: 70%; background: #fff;        border-radius: 8px;
                box-shadow: 0 5px 10px rgba(0, 0, 0, 0.1);}
                .search-containerB i {position: absolute; left: 20px; font-size: 16px; color: #707070;}
                #search-inputB{height: 100%; width: 100%; outline: none;  font-size: 16px;  font-weight: 400; border: none; padding-left: 50px;
                background-color: transparent;}
                @media screen and (max-width: 786px) {
                    .search-containerB{ width: 50%;}
                }
            </style>
            <script>
                document.addEventListener('DOMContentLoaded', function () {
                    const searchInput = document.getElementById('search-inputB');
                    const cards = document.querySelectorAll('.cards');
        
                    function filterIcons(searchQuery) {
                        const nothingfound = document.getElementById("nothing-alert");
                        let number = 0;
                        cards.forEach(function (card) {
                            const name = card.querySelector("h4").textContent.toLowerCase();
                            if (name.includes(searchQuery.toLowerCase())) {
                                nothingfound.style.display = "none";
                                card.style.display = "flex";
                                number++;
                            } else {
                                card.style.display = "none";
                            }
                        });
                        if(number == 0){
                            nothingfound.style.display = "block";
                        }
                    }
        
                    searchInput.addEventListener("input", function () {
                        const searchQuery = searchInput.value.trim();
                        filterIcons(searchQuery);
                    });
                });
            </script>
        


search images

Image search app

code:
            <div>
                <h4>Image search app</h4>
                <form class="first">
                    <input type="text" id="search-input-C" placeholder="Search for images..." />
                    <button id="search-button-C">Search</button>
                </form>
                <div class="search-results-C"></div>
                <button id="show-more-button">Show more</button>
            </div>
            <style>
                h4 {font-size: 3vw; font-weight: bold; text-align: center; margin-top: 1vw; margin-bottom: 3vw;}
                .first{display: flex; justify-content: center;  align-items: center; margin-bottom: 3vw;}
                #search-input-C {width: 60%;  max-width: 30vw; padding: 1vw 2vw; border: none; box-shadow: 0 0 5px rgba(0, 0, 0, 0.2);     border-radius: 0.3vw; font-size: 1vw; color: #333;}
                #search-button-C{padding: 1vw 2vw; background-color: #4caf50; color: white; border: none; font-size: 1vw; box-shadow: 0 0 5px rgba(0, 0, 0, 0.2); cursor: pointer; border-radius: 0.3vw; transition: background-color 0.3s ease-in-out; }
                #search-button-C:hover { background-color: #3e8e41;}
                .search-results-C {display: flex; flex-wrap: wrap; justify-content: space-between; max-width: 90vw; margin: 0 auto; padding: 1vw;}
                .search-result-C{ margin-bottom: 3vw; width: 30%; border-radius: 5px; box-shadow: 0 0 5px rgba(0, 0, 0, 0.2); overflow: hidden;
                }
                .search-result-C:hover img {transform: scale(1.05);}
                .search-result-C img {width: 100%; height: 200px; object-fit: cover;  transition: transform 0.3s ease-in-out;}
                .search-result-C a {padding: 10px;  display: block; color: #333; text-decoration: none; transition: background-color 0.3s ease-in-out;}
                .search-result-C:hover a {background-color: rgba(0, 0, 0, 0.1);}
                #show-more-button {background-color: #008cba; border: none; color: white; padding: 10px 20px; display: none; margin: 20px auto; text-align: center; border-radius: 5px; cursor: pointer; transition: background-color 0.3s ease-in-out; }
                #show-more-button:hover {background-color: #0077b5;}
                @media screen and (max-width: 768px) {
                    .search-result-C { width: 45%; }
                }
                @media screen and (max-width: 480px) {
                    .search-result {width: 100%;}
                    form {flex-direction: column;}
                    #search-input { margin-bottom: 20px;  width: 85%;}
                }
            </style>
            <script>
                const accessKey = "YOUR UNSPLASH API";
        
                const formEl = document.querySelector(".first");
                const searchInputEl = document.getElementById("search-input-C");
                const searchResultsEl = document.querySelector(".search-results-C");
                const showMoreButtonEl = document.getElementById("show-more-button");
        
                let inputData = "";
                let page = 1;
        
                async function searchImages() {
                inputData = searchInputEl.value;
                if(inputData.trim()){
                    const url = `../pics/?page=${page}&query=${inputData}&client_id=${accessKey}`;
                    const response = await fetch(url);
                    const data = await response.json();
                    if (page === 1) {
                        searchResultsEl.innerHTML = "";
                    }
                    const results = data.results;
                    results.map((result) => {
                        const imageWrapper = document.createElement("div");
                        imageWrapper.classList.add("search-result-C");
                        const image = document.createElement("img");
                        image.src = result.urls.small;
                        image.alt = result.alt_description;
                        const imageLink = document.createElement("a");
                        imageLink.href = result.links.html;
                        imageLink.target = "_blank";
                        imageLink.textContent = result.alt_description;
        
                        imageWrapper.appendChild(image);
                        imageWrapper.appendChild(imageLink);
                        searchResultsEl.appendChild(imageWrapper);
                    });
        
                    page++;
        
                    if (page > 1) {
                    showMoreButtonEl.style.display = "block";
                    }
                }
                }
        
                formEl.addEventListener("submit", (event) => {
                event.preventDefault();
                page = 1;
                searchImages();
                });
        
                showMoreButtonEl.addEventListener("click", () => {
                searchImages();
                });
            </script>